| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- import { NextApiRequest, NextApiResponse } from 'next'
- import NextAuth from 'next-auth'
- import Providers from 'next-auth/providers'
-
- export default function (req: NextApiRequest, res: NextApiResponse) {
- return NextAuth(req, res, {
- providers: [
- Providers.GitHub({
- clientId: process.env.GITHUB_ID,
- clientSecret: process.env.GITHUB_SECRET,
- scope: 'user',
- }),
- ],
- callbacks: {
- async redirect(url, baseUrl) {
- return url.startsWith(baseUrl) ? url : baseUrl
- },
- async signIn(user, account, profile) {
- // @ts-ignore
- const canLogin = await isSponsoringMe(profile?.login)
-
- if (canLogin) {
- return canLogin
- } else {
- return '/sponsorware'
- }
- },
- },
- })
- }
-
- const whitelist = ['steveruizok']
-
- async function isSponsoringMe(login: string) {
- if (whitelist.includes(login)) return true
-
- const res = await fetch('https://api.github.com/graphql', {
- method: 'POST',
- headers: {
- 'Content-Type': 'application/json',
- Authorization: 'bearer ' + process.env.GITHUB_API_SECRET,
- },
- body: JSON.stringify({
- query: `
- query {
- user(login: "steveruizok") {
- isSponsoredBy(accountLogin: "${login}")
- }
- }
- `,
- }),
- }).then((res) => res.json())
-
- return res?.data?.user?.isSponsoredBy
- }
|